<template>
  <div style="width: 100%">
    <a-card class="card" :bordered="false">
      <div class="table-page-search-wrapper">
        <a-form layout="vertical">
          <a-row :gutter="48">
            <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
              <a-form-item label="准考证号">
                <a-input placeholder="请输入..." v-model="queryParam.ksbh" />
              </a-form-item>
            </a-col>
            <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
              <a-form-item label="姓名">
                <a-input placeholder="请输入..." v-model="queryParam.ksxm" />
              </a-form-item>
            </a-col>
            <template v-if="advanced">
              <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
                <a-form-item label="招生年度">
                  <a-select :allowClear="true" showSearch optionFilterProp="children" v-model="queryParam.zsnj">
                    <a-select-option v-for="i in TYPE0126" :key="i.id" :value="i.code">{{ i.name }}</a-select-option>
                  </a-select>
                </a-form-item>
              </a-col>
              <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
                <a-form-item label="院系">
                  <a-select :disabled="selectMenu.yx.length === 1" :allowClear="true" showSearch optionFilterProp="children" v-model="queryParam.bkyxsm"
                    @change="yxChange">
                    <a-select-option v-for="i in selectMenu.yx" :key="i.id" :value="i.dwh">{{ i.dwh+"-"+ i.dwmc }}</a-select-option>
                  </a-select>
                </a-form-item>
              </a-col>
              <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
                <a-form-item label="专业">
                  <a-select :allowClear="true" showSearch optionFilterProp="children" v-model="queryParam.bkzydm" @change='zyChange'>
                    <a-select-option v-for="i in selectMenu.zy" :key="i.id" :value="i.zyh">{{i.zyh+'-'+ i.zymc }}</a-select-option>
                  </a-select>
                </a-form-item>
              </a-col>
              <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}" >
            <a-form-item label="研究方向">
            <a-select :allowClear="true" showSearch optionFilterProp="children" v-model="queryParam.lqyjfxm">
            <a-select-option v-for="i in selectMenu.fx" :key="i.id" :value="i.yjfxm">{{ i.yjfxm.substring(i.yjfxm.length-2) +"-"+ i.yjfxmc }}</a-select-option>
            </a-select>
          </a-form-item>
              </a-col>
              <a-col :sm="{span:12}" :lg="{span:12}" :xl="{span:6}">
                <a-form-item label="学习形式">
                  <a-select :allowClear="true" showSearch optionFilterProp="children" v-model="queryParam.zhxlxxxs">
                    <a-select-option v-for="i in selectMenu.xxlx" :key="i.id" :value="i.code">{{ i.name }}</a-select-option>
                  </a-select>
                </a-form-item>
              </a-col>
            </template>
            <a-col :sm="{span:20}" :xl="{span:10}">
              <a-button type="primary" @click="loadData">查询</a-button>
              <a-button type="primary" @click="handleExport">导出</a-button>
              <a-button type="primary" @click="handleBatchAudit">批量审核</a-button>
              <a @click="advanced = !advanced" style="margin-left: 8px">
                {{ advanced ? '收起' : '展开' }}
                <a-icon :type="advanced ? 'up' : 'down'" />
              </a>
            </a-col>
          </a-row>
        </a-form>
      </div>
    </a-card>
    <a-card class="card" :bordered="false">
      <a-table 
        ref="table" 
        size="default" 
        rowKey="key" 
        :columns="columns" 
        :loading="loading" 
        :dataSource="data"
        :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}" :pagination="pagination" @change="handleTableChange"
      >
        <template slot="ksbh" slot-scope="text,record">
          <a @click="handlePreview(record.id)">{{text}}</a>
        </template>
        <template slot="action" slot-scope="text,record">
          <a @click="handleAudit(record.id)">审核</a>
        </template>
        <span slot="serial" slot-scope="text, record, index">
          {{ index + 1 }}
        </span>
      </a-table>
      <!-- 审核 -->
      <audit-handle :AuditHandleVisible="AuditHandleVisible" :info='auditData' @quit="handleCloseAudit" @success="handleSubmitAudit"></audit-handle>
      <!-- 查看 -->
      <examinee :previewVisible="previewVisible" :info="examineeData" @close="handleClosePreview"></examinee>
    </a-card>
  </div>
</template>

<script>
  // import moment from 'moment'
  import AuditHandle from './auditHandle'
  import Examinee from '../../examinee/detail'
  import {
    STable
  } from '~'
  import {
    mapState
  } from 'vuex'

  const selectArr = ['TYPE0126', 'TYPE0075', 'TYPE0125', 'TYPE0072']

  export default {
    components: {
      STable,
      AuditHandle,
      Examinee
    },
    data() {
      return {
        advanced: true,
        AuditHandleVisible: false,
        previewVisible: false,
        loading: false,
        data: [],
        // 查询参数
        queryParam: {
          ksbh: '',
          ksxm: '',
          zhxlxxxs: '',
          bkyxsm: '',
          zsnj: '',
          bkzydm: ''
        },
        postParams: {},
        // 表头
        columns: [{
            title: '序号',
            scopedSlots: {
              customRender: 'serial'
            }
          },
          {
            title: '准考证号',
            dataIndex: 'ksbh',
            scopedSlots: {
              customRender: 'ksbh'
            }
          },
          {
            title: '姓名',
            dataIndex: 'ksxm'
          },
          {
            title: '录取院系',
            dataIndex: 'bkyxsmc'
          },
          {
            title: '报考专业代码',
            dataIndex: 'bkzydm'
          },
           {
            title: '录取专业代码',
            dataIndex: 'lqzym'
          },
          {
            title: '录取专业',
            dataIndex: 'bkzymc'
          },

          {
            title: '研究方向',
            dataIndex: 'bkyjfxmc'
          },
          {
            title: '初试成绩',
            dataIndex: 'zf'
          },
          {
            title: '复试成绩',
            dataIndex: 'fscj'
          },
          {
            title: '综合评定',
            dataIndex: 'zhpd'
          },
          {
            title: '综合排名',
            dataIndex: 'zhpm'
          },
          {
            title: '档案是否转入',
            dataIndex: 'dasfzr'
          },
          {
            title: '培养模式',
            dataIndex: 'pymsm'
          },
          {
            title: '录取类别',
            dataIndex: 'lqlbm'
          },
          {
            title: '学制',
            dataIndex: 'xz'
          },
          {
            title: '录取导师',
            dataIndex: 'bkdsyxm'
          },
          {
            title: '操作',
            dataIndex: 'cz',
            fixed: 'right',
            width: 120,
            scopedSlots: {
              customRender: 'action'
            }
          }
        ],
        // custom table alert & rowSelection
        options: {
          alert: {
            show: false
          },
          rowSelection: {
            onChange: (selectedRowKeys, selectedRows) => {
              console.log(`selectedRowKeys: ${selectedRowKeys}`, 'selectedRows: ', selectedRows)
            },
            onSelect: (record, selected, selectedRows) => {
              console.log(record, selected, selectedRows)
            },
            onSelectAll: (selected, selectedRows, changeRows) => {
              console.log(selected, selectedRows, changeRows)
            }
          }
        },
        selectMenu: {
          yx: [], // 院系
          zy: [],
          xxlx: [],
        },
        examineeData: {},
        selectedRowKeys: [],
        selectedRows: [],
        pagination: {
          current: 1,
          showSizeChanger: true,
          pageSizeOptions: ['10', '50', '100'],
          // 改变pageSize后触发
          onShowSizeChange: (current, pageSize) => this.pagination.pageSize = pageSize,
        },
        auditData: {
          id: '',
          chekType: ''
        }
      }
    },
    computed: {
      ...mapState({
        systemInfo: state => state.app.systemInfo,
        TYPE0126: state => state.app['TYPE0126'] // 年级
      })
    },
    created() {
      this.initSelectMenu()

      selectArr.forEach(v => {
        this.$store.dispatch('app/setDictionary', v)
      })
    },
    methods: {
      filterOption(input, option) {
        return option.componentOptions.children[0].text.toLowerCase().indexOf(input.toLowerCase()) >= 0
      },
      initSelectMenu() {
        let allRequest = [
          this.$api.base.collegeAll()
        ]
        Promise.all(allRequest).then(res => {
          this.selectMenu = {
            yx: res[0].data
          }
          // 获取学习形式
          this.$api.base.dictionaryData('TYPE0441').then(res => {
            this.selectMenu.xxlx = res.data
          })
          this.queryParam.bkyxsm = res[0].data[0].dwh
          this.getProssion(this.queryParam.bkyxsm)
          // 获取当前学年
          this.$api.base.getSchoolYear().then(res => {
            this.queryParam.zsnj = res.data.masterAdmissionYear
            this.loadData({
              pageSize: 10,
              pageNum: 1
            })
          })
        })
      },
      // 选择院系
      yxChange(code) {
        this.$set(this.queryParam, 'bkzydm', '')
        this.$set(this.selectMenu, 'zy', [])
        if(code){

        this.getProssion(code)
        }
      },
      getProssion(code) {
        this.$api.base.majorAll({
          lsdwh: code
        }).then(res => {
          this.$set(this.selectMenu, 'zy', res.data)
        })
      },
      //选择专业
    zyChange(code){
       this.$set(this.queryParam, 'lqyjfxm', '')
        this.$set(this.selectMenu, 'fx', [])
        if(code){
          this.getDurection(code)
        }
    },
    getDurection(code) {
        this.$api.base.searchDirectory({
          ssyxm: this.queryParam.bkyxsm,
          zsxn: this.queryParam.zsnj,
          sszym: code,
           xwccm: 2
        }).then(res => {
          this.$set(this.selectMenu, 'fx', res.data)
        })
      },
      // 加载数据
      loadData(parameter = {}) {
        if (!parameter.pageNum) {
          this.pagination.current = 1
          parameter.pageNum = 1
        }
        console.log(this.pagination.pageSize)
        let params = Object.assign(this.queryParam, parameter)
        this.loading = true
        this.$api.recruitstat.admissionAuditList(params).then(res => {
          const pagination = { ...this.pagination
          };
          pagination.total = 0
          if (res.data && res.data.total) {
            pagination.total = res.data.total;
          }
          this.data = []
          this.pagination = pagination;
          if (res.data && res.data.rows.length) {
            this.data = res.data.rows;
          }
          this.loading = false;
        })
      },
      // 分页
      handleTableChange(pagination, filters, sorter) {
        console.log(pagination);
        const pager = { ...this.pagination
        };
        pager.current = pagination.current;
        this.pagination = pager;
        this.loadData({
          pageSize: this.pagination.pageSize,
          pageNum: pagination.current
        });
      },
      // 多选
      onSelectChange(selectedRowKeys, selectedRows) {
        console.log('selectedRowKeys changed: ', selectedRowKeys);
        this.selectedRows = selectedRows
        this.selectedRowKeys = selectedRowKeys
      },
      // 选择招生年度
      zsndChange() {

      },
      // 导出
      handleExport() {
        console.log('导出')
        this.$export('admissions/ssrqsh/export', this.queryParam)
      },
      // 审核
      handleAudit(code) {
        console.log('审核', code)
        this.AuditHandleVisible = true
        var newObj = {
          id: code,
          chekType: 'single'
        }
        this.auditData = newObj
      },
      // 批量审核
      handleBatchAudit() {
        console.log('批量审核')
        var deleteId = ''
        if (!this.selectedRowKeys.length) {
          this.$message.warning('请选择需要审核的数据')
          return
        }
        if (this.selectedRows && this.selectedRows.length) {
          deleteId = this.selectedRows.map(v => {
            return v.id
          }).toString()
        }
        console.log(deleteId)
        var newObj = {
          id: deleteId,
          chekType: 'multiply'
        }
        this.auditData = newObj
        this.AuditHandleVisible = true
      },
      // 保存审核
      handleSubmitAudit(d) {
        console.log(d)
        this.AuditHandleVisible = false
        this.loadData({
          pageSize: 10,
          pageNum: this.pagination.current
        })
        // this.selectedRows = []
        this.selectedRowKeys = []
      },
      // 取消审核
      handleCloseAudit() {
        this.AuditHandleVisible = false
      },
      // 查看考生详情
      handlePreview(code) {
        this.$api.recruitstat.masterAdmissionManageId(code).then(res => {
          this.examineeData = res.data
          this.previewVisible = true
        })
      },
      // 关闭考生想去
      handleClosePreview() {
        this.previewVisible = false
      }
    }
  }
</script>

<style lang="less" scoped>
  .card {
    margin-bottom: 20px;
  }
</style>
